// pages/classify/classify.js
Page({
  getData() {
    // 函数节流
    this.setData({
      isLoading: true
    })
    // 打开loading
    wx.showLoading({
      title: '数据加载中...',
    })
    // 发送请求
    wx.request({
      url: 'http://localhost:3000/list',
      method: 'GET',
      data: {
        _page: this.data._page
      },
      success: ({
        data
      }) => {
        // 判断是否请求完毕
        if (data.length > 0) {
          this.setData({
            list: [...this.data.list, ...data],
            _page: this.data._page + 1
          })
        } else {
          // 没有更多数据 设置开关
          this.setData({
            isFinished: true
          })
        }

      },
      fail(error) {
        console.log("请求失败", error)
      },
      complete: () => {
        // 函数节流
        this.setData({
          isLoading: false
        })
        // 关闭loading
        wx.hideLoading()
      }
    })
  },
  /**
   * 页面的初始数据
   */
  data: {
    list: [],
    _page: 1,
    // 表数据是否加载完毕
    isFinished: false,
    // 表示数据是否正在请求
    isLoading: false
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    this.getData()
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    this.setData({
      list: [],
      _page: 1
    })
    this.getData()
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    // 数据是否完成
    if(this.data.isFinished) return;
    // 数据是否正在请求
    if(this.data.isLoading) return;
    // 请求数据
    this.getData()
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})